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CLOCK DATA RECOVERY DESERIALIZER 
WITH PROGRAMMABLE SYNC DETECT LOGIC 



BACKGROUND OF THE INVENTION 

1. Field of the Invention 

The present invention relates generally to SERDES (serializer/deserializer) 
transceivers, and more particularly, to a CDR (clock data recovery) deserializer with 
programmable synchronization bit patterns such that the RPDO (recovered parallel data 
output) are comprised of properly partitioned bits of the recovered serial data for high speed 
serial data input (SDIN) of multiple communications protocols. 

2. Discussion of the Related Art 

Fig, 1 shows a conventional SERDES (serializer/deserializer) transceiver 100 
coupled between a high speed data communication media 102 and a low speed data processor 
104. The high speed data communication media 102 is for sending serial data bits to the low 
speed data processor 104 at relatively high speeds. The low speed data processor 104 then 
receives and processes such data at a lower speed. For example, the high speed data 
communication media 102 may be a network of optical fibre channels operating at the 
relatively high speed of 1.25 GHz (giga-Hertz) for instance, and the low speed data processor 
104 may be a computer system for processing such data received from the high speed data 
communication media 102. Such high speed data communication media 102 and such low 
speed data processor 104 are known to one of ordinary skill in the art of SERDES 
transceivers. 

Within the SERDES transceiver 100, a clock data recovery deserializer 106 receives a 
high speed serial data input (SDIN) from the high speed data communication media 102 and 
recovers an embedded serial clock signal (SCLK) from the high speed serial data input 
(SDIN). The clock data recovery deserializer 106 uses a plurality of given clock signals 
(HCLKiJ generated by a clock synthesizer phase locked loop 108 to recover the serial clock 
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signal (SCLK). The clock synthesizer phase locked loop 108 generates each of the plurality 
of given clock signals (HCLKj J from a reference clock signal (REFCLK) provided by the 
low speed data processor 104. Each of the plurality of given clock signals (HCLK,.J has a 
substantially same frequency that is an expected frequency of the recovered serial clock 
signal (SCLK) of the high speed serial data input (SDIN) but has different phases from each 
otiier. 

In addition, the clock data recovery deseriahzer 106 uses the recovered serial clock 
signal (SCLK) to sample the high speed serial data input (SDIN) for generating a v-bits wide 
recovered parallel data output (RPDO) for every cycle of a recovered parallel clock signal 
(RPCLK). The recovered parallel clock signal is generated for every v-cycles of the 
recovered serial clock signal (SCLK). The recovered parallel data output (RPDO) and the 
recovered parallel clock signal (EIPCLK) are sent from the clock data recovery deserializer 
1 06 to the low speed data processor 104 for ftulher processing of such data at relatively 
slower speeds by the low speed data processor 104. 

The reference clock signal (REFCLK) from the low speed data processor 104 and the 
recovered parallel clock signal (RPCLK) have a substantially same frequency since the ratio 
of the frequency of the recovered serial clock signal (SCLK) to the frequency of the reference 
clock signal (REFCLK) or to the frequency of the recovered parallel clock signal (RPCLK) is 
substantially same. The ratio of tiie frequency of the recovered serial clock signal (SCLK) to 
the frequency of the reference clock signal (REFCLK) or to the frequency of the recovered 
parallel clock signal (RPCLK) is "v" with the recovered parallel data output (RPDO) being 
"v"-bits wide. However, the phase of the reference clock signal (REFCLK) may differ from 
the phase of the recovered parallel clock signal (RPCLK) smce the recovered parallel clock 
signal (RPCLK) is synchronized with the output of the v-bits wide recovered parallel data 
output (RPDO). 

On the transmitting side, a transmit serializer 110 receives a v-bits wide transmitted 
parallel data input (TPDIN) and the reference clock signal (REFCLK) from the low speed 
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data processor 104. The reference clock signal (REFCLK) is synchronized with the v-bits 
wide transmitted parallel data input (TPDIN). The transmit serializer 1 10 uses the higher 
frequency of a given clock signal (HCLK) from the clock synthesizer phase locked loop 108 
to convert the v-bits wide transmitted parallel data input (TPDIN) to a high speed serial data 
output (SDOUT) to be transmitted over the high speed data communication media 102. The 
high speed serial data output (SDOUT) is transmitted as serial data bits at the higher speed of 
the given clock signal (HCLK) which has a substantially same frequency as the recovered 
serial clock signal (SCLK). 

Such a SERDES transceiver 100 and such operations and components 106, 108, and 
1 10 of the SERDES transceiver 100 are known to one of ordinary skill in the art of high 
speed data communications. 

Fig. 2 shows the components of the clock data recovery deserializer 106 of Fig. 1. A 
clock recovery phase locked loop 1 12 inputs the high speed serial data input (SDIN) and 
generates the recovered serial clock signal (SCLK). The recovered serial clock signal 
(SCLK) is mput by a clock divider 1 14 and a serial-to-parallel shift register 1 16. The serial- 
to-parallel shift register 116 shifts in a bit of the high speed serial data input (SDIN) every 
cycle of the recovered serial clock signal (SCLK). 

The clock divider generates the recovered parallel clock signal (RPCLK) having a 
cycle for every ' V cycles of the recovered serial clock signal (SCLK). The recovered 
parallel clock signal (RPCLK) is input by the serial-to-parallel shift register 1 16 to generate 
the recovered parallel data output (RPDO) comprised of v-bits of the high speed serial data 
input (SDIN) at a predetermined transition of every cycle of the recovered parallel clock 
signal (RPCLK). A SYNC detect logic 1 18 asserts a VRS (divider ReSet) signal (i.e., a 
parallel clock enabling signal) for determining the timing of such a predetermined transition 
of every cycle of the recovered parallel clock signal (RPCLK) such that the high speed serial 
data input (SDIN) is properly partitioned to generate each of the v-bits of the recovered 
parallel data output (RPDO). The SYNC detect logic 118 inputs the high speed serial data 
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input (SDIN) and asserts the VRS signal at the occurrence of a predetermined bit pattern 
within the high speed serial data input (SDIN). 

Such a clock data recovery deserializer 106 and such operations and components 112, 
1 14, 116, and 1 18 of the clock data recovery deserializer 106 are known to one of ordinary 
skill in the art of SERDES transceivers. 

Fig. 3 shows a timing diagram of an example high speed serial data input (SDIN) 101, 
an example recovered serial clock signal (SCLK) 103, and examples of possible recovered 
parallel clock signals (RPCLK). The cross-hatched region of the high speed serial data input 
(SDIN) 101 represents a time period when the high speed serial data input (SDIN) 101 may 
make a transition, and the time period between the cross-hatched regions rq)resents a time 
period when the high speed serial data input (SDIN) 101 has a stable data bit, including a first 
data bit 105, a second data bit 107, a third data bit 109, a fourth data bit 1 1 1, and a fifth data 
bit 1 13. The example recovered serial clock signal (SCLK) 103 represents a desired 
recovered serial clock signal (SCLK) with each low-to-high transition of the recovered serial 
clock signal (SCLK) 103 occurring substantially at the middle of each stable data bit of the 
high speed serial data input (SDIN) 101 (as illustrated by dashed line 1 15 for example in Fig. 
3). 

Referring to Figs, 2 and 3, assume tiiat the recovered parallel data output (RPDO) is 
comprised of three-bits, and that the proper partitioning of three data bits in Fig. 3 is to 
include the fu-st, second, and third data bits 105, 107, and 109. For such three data bits, a 
first recovered parallel clock signal (RPCLKj) 1 17, a second recovered parallel clock signal 
(RPCLK2) 119, and a third recovered parallel clock signal (RPCLK3) 121 are possible. If the 
three data bits after the low-to-high transition of the recovered parallel clock signal (RPCLK) 
is to comprise the three-bits of the recovered parallel data output (RPDO), then for a cycle 
123 of the first recovered parallel clock signal (RPCLKi) 1 17, the recovered parallel data 
output (RPDO) is comprised of the first, second, and third data bits 105, 107, and 109, On 
the other hand, for a cycle 125 of the second recovered parallel clock signal (RPCLK2) 119, 
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the recovered parallel data output (RPDO) is comprised of the second, third, and fourth data 
bits 107, 109, and 1 1 1. For a cycle 127 of the third recovered parallel clock signal (RPCLK3) 
121, the recovered parallel data output (RPDO) is comprised of the third, fourth, and fifth 
data bits 109, 111, and 113. 
5 Thus, if the proper partitioning of the high speed serial data input (SDIN) 101 is to 

include the three-bits of the first, second, and third data bits 105, 107, and 109, then the first 
recovered parallel clock signal (RPCLKj) 1 17 is the desired one of the possible first, second, 
and third recovered parallel clock signals (RPCLKj, RPCLK2, and RPCLK3) 1 17, 1 19, and 
121 . The VRS signal firom the SYNC detect logic 118 determines the time of occurrence of 
10 the low-to-high transition of the recovered parallel clock signal (RPCLK) to ensure that the 

^ first recovered parallel clock signal (RPCLKi) 1 17 (instead of the second or third possible 

£3 

Q recovered parallel clock signals RPCLK2 and RPCLK3) is the recovered parallel clock signal 
^ (RPCLK) sent to the serial-to-parallel shift register 116. 

The SYNC detect togic 118 asserts the VRS signal at the occurrence of a 

1 50 predetermined synchronization bit pattem within the high speed serial data input (SDIN). 

i . 

One of the drawbacks of conventional SERDES transceivers is their inabiUty to recognize 
y synchronization bit patterns of different communications protocols. In prior art SERDES 
W transceivers, the SYNC detect logic is constructed to recognize only a single synchronization 
hh bit pattem. Different communications protocols, however, have different synchronization bit 
20 patterns. A SERDES transceiver having such prior art SYNC detect logic 118 cannot receive 

and process high speed serial data input (SDIN) having different synchronization bit patterns. 

Another drawback of conventional SERDES transceivers is their inability to 
minimize bit error rates for different communications protocols. Fig. 4 shows the prior art 
components of the clock recovery phase locked loop 1 12 of Fig. 2 including a phase detector 
25 120, a digital filter 122, and a phase selector 124 for generating the recovered serial clock 

signal (SCLK) firom the high speed serial data input (SDIN). The phase selector 124 inputs 
the given clock signals (HCLKi^J fi-om the clock synthesizer phase locked loop 108 of Fig. 1 
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and selects one of such given clock signals as the recovered serial clock signal (SCLK). The 
phase selector 124 selects one of the given clock signals (HCLKi^J as the recovered serial 
clock signal (SCLK) depending on the values of a FWD signal and a BWD signal generated 
by the digital filter 122. 

5 Fig. 5 shows a timing diagram of an example high speed serial data input (SDIN) 130 

and an example recovered serial clock signal (SCLK) 134. A complementary recovered 
serial clock signal (ACLK) 132 is the recovered serial clock signal (SCLK) 134 that is ISC' 
phase-shifted. The cross-hatched region of the high speed serial data input (SDIN) 130 
represents a transition time period when the high speed serial data input (SDIN) 130 may 
1 0 make a transition, and the time period between the cross-hatched regions represents a stable 

|j data time period when the high speed serial data input (SDIN) 130 has a stable data bit/ 

Q For the desired recovered serial clock signal (SCLK) 134 and the desired 

0- 

1^ complementary recovered serial clock signal (ACLK) 132, each low-to-high transition of the 
complementary recovered serial clock signal (ACLK) 132 occurs substantially at the middle 
1 513 of the cross-hatched region representing the transition time period when the high speed serial 
data input (SDIN) 130 makes a transition (illustrated by dashed line 133 in Fig. 5). 

hi 

]^ Conversely, each low-to-high transition of the recovered serial clock signal (SCLK) 134 
y occurs substantially at the middle of the region representing the stable data time period when 
the high speed serial data input (SDIN) 130 has a stable data bit (illustrated by dashed line 
20 135 in Fig. 5). 

Fig. 5 also shows example given clock signals (HCLKj.J from the clock synthesizer 
phase locked loop 108 of Fig. 1 including a first given clock signal HCLKj 136, a second 
given clock signal HCLKj 138, a third given clock signal HCLK3 140, a fourth given clock 
signal HCLK4 142, a fifth given clock signal HCLK5 144, a sixth given clock signal HCLK^ 
25 146, a seventh given clock signal HCLK7 148, and an eighth given clock signal HCLKg 150. 

Each of the given clock signals (HCLKi J are arranged in a predetermined phase order such 
that any two adjacent given clock signals (HCLKj and HCLKj+i) have a substantially same 
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predetermined phase difference. In addition, the first given clock signal HCLKj 136 and the 
eighth given clock signal HCLKg 150 which is the last of the given clock signals (HCLKj.J 
in the phase order in the example of Fig. 5 has that substantially same predetermined phase 
difference. Thus, the example given clock signals (HCLK^J of Fig. 5 have a successive 
phase difference of 45°. 

If the FWD signal is asserted by the digital filter 122, then the phase selector 124 
selects another clock signal (HCLKj+j) of the given clock signals that immediately leads a 
priorly selected one (HCLKj) of the given clock signals as the recovered serial clock signal 
(SCLK). If the BWD signal is asserted by the digital filter 122, then the phase selector 124 
selects another clock signal (HCLKj.i) of the given clock signals that immediately lags the 
priorly selected one (HCLK|) of the given clock signals as the recovered serial clock signal 
(SCLK). If neither the FWD signal nor the BWD signal is asserted, then the phase selector 
124 selects the priorly selected one (HCLK,) of the given clock signals to remain as the 
recovered serial clock signal (SCLK). In the example of Fig. 5, eventually, the seventh given 
clock signal HCLK7 is selected as the desired recovered serial clock signal (SCLK) 134, and 
the third given clock signal HCLK3 is selected as the desired complementary recovered serial 
clock signal (ACLK) 132. 

The phase detector 120 inputs the high speed serial data input (SDIN) and compares 
the phase of the high speed serial data input (SDIN) to the phase of the recovered serial clock 
signal (SCLK) firom the phase selector 124. The phase detector 120 generates a DN signal 
pulse if the high speed serial data input (SDIN) leads the recovered serial clock signal 
(SCLK) and generates an UP signal pulse if the high speed serial data input (SDIN) lags the 
recovered serial clock signal (SCLK). The digital filter 122 counts the number of such UP 
signal pulses to assert the FWD signal after generation of at least a predetermined number of 
UP signal pulses or to assert the BWD signal after generation of at least a predetermined 
number of DN signal pulses. Such a clock recovery phase locked loop 1 12 which is a digital 
phase locked loop and such operations and components 120, 122, and 124 of the clock 
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recovery phase locked loop 1 12 are known to one of ordinary skill in the art of SERDES 

transceivers* 

Assertion of the FWD signal or the BWD signal by the digital filter 122 after 
counting such UP signal pulses or DN signal pulses to at least the predetermined number 
ensures that the FWD signal or the BWD signal is asserted only when the high speed serial 
data input (SDIN) significantly leads or lags the recovered serial clock signal (SCLK). In 
this manner, the FWD signal or the BWD signal is not asserted when the high speed serial 
data input (SDIN) leads or lags the recovered serial clock signal (SCLK) only because of 
temporary glitches or noise. 

In addition, the digital filter 122 determines an average (i.e., a trend) of whether the 
high speed serial data input (SDIN) leads or lags the recovered serial clock signal (SCLK) by 
counting such UP signal pulses or DN signal pulses to at least the predetermined number. 
When the phase detector 120 generates the UP signal pulses and the DN signal pulses by 
comparing the transitions of the high speed serial data input (SDIN) to the transitions of the 
recovered serial clock signal (SCLK), the predetermined number of the UP signal pulses and 
the DN signal pulses that the digital filter 122 counts up to for asserting the FWD signal or 
the BWD signal determines the bit error rate of the SERDES transceiver 100, as known to 
one of ordinary skill in the art of SERDES transceivers. 

In the prior art digital filter 122, this predetermined number of the UP signal pulses 
and the DN signal pulses that the digital filter 122 counts up to for asserting the FWD signal 
or the BWD signal is fixed. However, each communications protocol has a respective 
optimum range of the predetermined number of UP signal pulses and the DN signal pulses 
that the digital filter coxmts up to for asserting the FWD signal or the BWD signal such that 
the bit error rate is minimized for each communications protocol. When the predetermined 
number of UP signal pulses and the DN signal pulses that the digital filter 122 counts up to 
for asserting the FWD signal or the BWD signal is fixed for a predetermmed communications 
protocol, the SERDES transceiver having such a prior art digital filter 122 cannot be used for 
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receiving and processing high speed serial data input (SDIN) of another communications 
protocol with minimized bit error rate for that other communications protocol. 

In the prior art, another SERDES transceiver having a digital filter that counts to a 
different predetermined number of the UP signal pulses and the DN signal pulses for 
5 asserting the FWD signal or the BWD signal needs to be manufactured to minimize the bit 

error rate of another communications protocol. However, such manufacture of various 
SERDES transceiver to accommodate different communications protocols may be costly. 
Nevertheless, the high speed serial data input (SDESf) may be communicated according to 
multiple communications protocols. 
10 A third drawback of conventional SERDES transceivers is their inability to provide 

H additional phases of the recovered clock signal (SCLK) without minimized consumption of 
□ increased chip area and power since each additional phase interpolator consumes additional 
M chip area and power. 

I ; 

150 SUMMARY 

^ Accordingly, in one aspect of the present invention, a CDR (clock data recovery) 

^ deserializer is implemented with a synchronization detect logic having programmable 

y i synchronization bit pattems such that the RPDO (recovered parallel data output) are 

0 . 

comprised of prop^ly partitioned bits of the recovered serial data for high speed serial data 

20 input (SDIN) of multiple communications protocols. 

hi one example embodiment, a CDR (clock data recovery) deserializer comprises a 
clock divider operable to receive a recovered clock signal (SCLK) and to generate a divided 
clock signal (RPCLK) for every given number of recovered clock signal cycles. In addition, 
a serial-to-parallel shift register is responsive to the recovered clock signal to shift in 

25 recovered serial data bits and is responsive to the divided clock signal to shift out recovered 

parallel data bits. Furthermore, sync detect logic is coupled to the clock divider and is 
operable to assert a parallel clock enabling signal that enables the clock divider to generate 
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the divided clock signal. The sync detect logic includes a reloadable register operable to 
store a programmable synchronization bit pattem associated with a communications protocol 
and a bit pattem comparator operable to compare the stored programmable synchronization 
bit pattem with a synchronization bit pattem within the recovered serial data bits and to assert 
or not assert the parallel clock enabling signal as a result of the comparison. 

In another embodiment of a CDR (clock data recovery) deserializer, a clock divider 
receives a recovered clock signal having a first frequency and generates a divided clock 
signal having a second frequency. The second frequency of the divided clock signal is 
lowered from tihie first frequency of the recovered clock signal by a predetermined ratio 
nxmiber such that each cycle of the divided clock signal is generated for each count of cycles 
of the recovered clock signal up to the predetermined ratio number. A serial-to-parallel shift 
register shifts in recovered serial data bits with each cycle of the recovered clock signal and 
outputs, as a RPDO (recovered parallel data output), the predetermined ratio number of the 
shifted recovered serial data bits at a predetermined transition of every cycle of the divided 
clock signal. 

In addition, a SYNC (synchronization) detect logic asserts a VRS (divider ReSet) 
signal coupled to the clock divider for controlling the clock divider to generate the 
predetermined transition for a cycle of the divided clock signal when the VRS signal is 
asserted. The SYNC detect logic includes a plurality of reloadable register portions for 
storing a plurality of synchronization bit pattems for a plurality of communications protocols. 
Each of a plurality of bit pattem comparators inputs the predetermined ratio number of bits 
comprising an intermediate parallel data ou^ut (IPDO) with each cycle of the recovered 
clock signal. A bit of the recovered serial data bits is shifted in every recovered clock signal 
by the shift register to generate the mtermediate parallel data output (IPDO). Each of the 
plurality of bit comparators compares for every cycle of the recovered clock signal the 
intermediate parallel data output (IPDO) to each of the synchronization bit pattems. A 
multiplexer selects one of the outputs of the bit pattem comparators as the VRS signal 
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depending on the communications protocol of the recovered serial data bits. 

In this manner, the VRS signal is asserted differently depending on the 
communications protocol of the high speed serial data input (SDIN) to properly partition the 
recovered serial data (RSD) to form the recovered parallel data output (RPDO). Thus, the 
CDR (clock data recovery) deserializer accommodates multiple communications protocols of 
the high speed serial data input (SDIN) for proper partitioning of the recovered serial data 
(RSD) to form the recovered parallel data output (RPDO). 

These and other features and advantages of the present invention will be better 
understood by considering the following detailed description of the invention which is 
presented with the attached drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 shows block diagram components of a SERDES (serializer/deserializer) 
transceiver as known in the prior art; 

Fig. 2 shows block diagram components of a clock data recovery deserializer of the 
SERDES transceiver of Fig. 1, according to the prior art; 

Fig. 3 shows an example timing diagram illustrating possible first, second, and third 
recovered parallel clock signals (RPCLKi, RPCLK2, and RPCLK3) from a clock divider of 
the clock data recovery deserializer of Fig. 2, according to the prior art; 

Fig. 4 shows block diagram components of a clock recovery phase locked loop of the 
clock data recovery deserializer of Fig. 2, according to the prior art; 

Fig. 5 shows an example timing diagram illustrating generation of the recovered serial 
clock signal (SCLK) by selecting one of a plurahty of given clock signals (HCLKj.n), 
according to the prior art; 

Fig. 6 shows block diagram components of a digital filter having programitiable 
bandwidth parameters for minimizing the bit error rate for high speed serial data input 
(SDIN) of multiple communications protocols, according to one aspect of the present 
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Fig. 7 shows further block diagram components for the digital filter of Fig. 6 for 
programming the bandwidth parameters by software from a computer system, according to 
one embodiment of the present invention; 

Fig. 8 shows a flow chart during operation of the digital filter of Fig. 6, according to 
an embodiment of the present invention; 

Fig. 9 illustrates a Gaussian distribution of the probability of occurrences of a data 
transition within a relatively large transition time period of the high speed serial data input 
(SDIN), as the digital filter of Fig. 6 operates in a tracking mode; 

Fig. 10 illustrates a Gaussian distribution of the probability of occurrences of a data 
transition within a relatively small transition time period of the high speed serial data input 
(SDIN), as the digital filter of Fig, 6 operates in a locking mode; 

Fig. 1 1 shows block diagram components of a phase selector for generating the 
recovered serial clock signals (SCLK and ACLK) with more possible phases than just the 
phases of given clock signals (HCLKi.^) but with a minimized number of phase interpolators, 
according to another aspect of the present invention; 

Fig. 12 shows block diagram components of a phase select signal generator 
comprised of a loop of bidirectional flip-flops for generating a plurality of phase select 
signals within the phase selector of Fig. 11, according to one embodiment of the present 
invention; 

Fig. 13 shows block diagram components of a bidirectional set flip-flop used as a first 
bidirectional flip-flop in the phase select signal generator of Fig. 12, according to one 
embodiment of the present invention; 

Fig, 14 illustrates the control signals for controlling the output of each of the 
bidirectional flip-flops within the phase select signal generator of Fig. 12, according to one 
embodiment of the present invention; 

Fig. 15 shows block diagram components of a bidirectional reset flip-flop used as the 
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bidirectional flip-flops after the first bidirectional set flip-flop of Fig. 13 in the phase select 
signal generator of Fig. 12, according to one embodiment of the present invention; 

Fig. 16 shows a table of input clock signals and the output clock signal for a first 
phase interpolator for generating the recovered serial clock signal (SCLK), according to one 
embodiment of the present invention; 

Fig. 17 shows a table of input clock signals and the output clock signal for a second 
phase interpolator for generating the complementary recovered serial clock signal (ACLK), 
according to one embodiment of the present invention; 

Fig. 18 shows block diagram components of a clock data recovery deserializer having 
a SYNC detect logic with a plurality of programmable synchronization bit patterns for 
ensuring proper partitioning of the high speed serial data input (SDIN) to generate the v-bits 
wide recovered parallel data output (RPDO) for multiple communications protocols, 
according to another aspect of the present invention; 

Fig. 19 shows block diagram components of the SYNC detect logic, of the clock data 
recovery deserializer of Fig. 18, having a multiplexer disposed after a plurality of bit pattem 
comparators, according to one embodiment of the present invention; 

Fig. 20 shows further block diagram components for the SYNC detect logic of Figs. 
19 for programming the plurahty of synchronization bit pattems into a pluraHty of reloadable 
registers for multiple communications protocols by software from a computer system, 
according to one embodiment of the present invention; 

Fig. 21 shows further block diagram components for the SYNC detect logic of Figs. 
19 for programming the plurahty of synchronization bit pattems into one reloadable register 
for miJtiple communications protocols by software from a computer system, according to 
another embodiment of the present invention; and 

Fig. 22 shows block diagram components of the SYNC detect logic, of the clock data 
recovery deserializer of Fig. 18, having a multiplexer disposed after a plurality of registers 
and disposed before a bit pattem comparator, according to another embodiment of the present 
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The figures referred to herein are drawn for clarity of illustration and are not 
necessarily drawn to scale. Elements having the same reference number in Figs. 1, 2, 3, 4, 5, 
6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, and 22 refer to elements having 
similar structure and function. 

DETAILED DESCRIPTION 

Referring to Fig. 6, a clock recovery phase locked loop 200 of an embodiment of the 
present invention includes a phase transition detector 202, a digital filter 204, and a phase 
selector 206. The phase selector 206 receives a predetermined number of given clock signals 
(HCLK|,n) such as the given clock signals (HCLKi.n) of Fig. 5 and generates the recovered 
serial clock signal (SCLK) and the complementary recovered clock signal (ACLK) that is 
180° phase shifted firom the recovered serial clock signal (SCLK). 

Referring to Figs. 6 and 8, the components of the digital filter 204 (shown within 
dashed lines in Fig. 6) of an embodiment of the present invention and the phase transition 
detector 202 operate according to the flow chart of Fig. 8. The phase transition detector 202 
inputs the high speed serial data input (SDIN), the recovered serial clock signal (SCLK), and 
the complementary recovered clock signal (ACLK). The high speed serial data input (SDIN), 
the recovered serial clock signal (SCLK), and the complementary recovered clock signal 
(ACLK) have the desired phase relation of Fig. 5. Each low-to-high transition of the 
recovered serial clock signal (SCLK) is desirably centered about a stable data bit of the high 
speed serial data input (SDIN) (as illustrated by dashed line 135 in Fig. 5). Each low-to-high 
transition of the complementary recovered serial clock signal (ACLK) is desirably centered 
about a transition time period when the high speed serial data input (SDIN) may make a 
transition (as illustrated by dashed line 133 in Fig. 5). 

The phase transition detector 202 compares the timing of such transitions of the 
recovered serial clock signal (SCLK) and the complementary recovered clock signal (ACLK) 
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and the transitions of the high speed serial data input (SDIN) to generate an UP signal pulse 
or a DN signal pulse (step 262 of Fig. 8), The phase transition detector 202 generates an UP 
signal pulse when the phase of the high speed serial data input (SDIN) leads the phase of the 
complementary recovered clock signal (ACLK) (st^ 264 of Fig, 8) and generates a DN 
signal pulse when the phase of the hi^ speed serial data input (SDIN) lags the phase of the 
complementary recovered clock signal (ACLK) (step 266 of Fig. 8). Implementation for 
such a phase transition detector 202 is known to one of ordinary skill in the art of electronics. 

In addition, implementation of the phase transition detector 202 for generating a 
recovered serial data (RSD) is known to one of ordinary skill in the art of electronics. The 
recovered serial data (RSD) is the high speed serial data input (SDIN) sampled at every cycle 
of the recovered serial clock signal (SCLK). Thus, the recovered serial data (RSD) is ideally 
substantially same as the high speed serial data input (SDIN). Mechanisms within the phase 
transition detector 202 for sampUng a data signal with a clock signal to generate the 
recovered serial data (RSD) are known to one of ordinary skill in the art. 

The digital filter 204 includes an up_counter 212 for counting up each UP signal 
pulse from the phase transition detector 202 to generate an UP_CNT value (step 264 of Fig. 
8). Similarly, a down_counter 214 counts up each DN signal pulse from the phase transition 
detector 202 to generate a DN_CNT value (step 266 of Fig. 8). Referring to Fig. 8, at start of 
operation of the digital filter 204, a LOCK signal is reset to be imasserted at a logical low "0" 
state (step 259 of Fig. 8), and at that point, the phase selector 206 selects one of the given 
clock signals (HCLKj. J as the initial SCLK signal and one of the given clock signals 
(HCLKi.J as the initial ACLK signal. In addition, the up_counter 212 and the down_counter 
214 are reset to zero (step 260 of Fig. 8). Implementation of counters for counting signal 
pulses are known to one of ordinary skill in the art of electronics. 

An adder 216 adds the UP_CNT value from the up_counter 212 and the DN_CNT 
value from the down_counter 214 to generate a SUM value (i.e., SUM = UP_CNT + 
DN_CNT) (step 268 of Fig. 8). A subtractor 218 subtracts the UP^CNT value from the 
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DN_CNT value to generate a DELTA value (i.e., DELTA = DN_CNT - UP_CNT) (step 268 
of Fig. 8). Implementation of adders and subtractor are known to one of ordinary skill in the 
art of electronics. 

In addition, the digital filter 204 of an embodiment of the present invention includes a 
plurality of reloadable register portions including a first LK (lock) reloadable register portion 
222, a second LK (lock) reloadable register portion 224, a first TK (track) reloadable register 
portion 226, and a second TK (track) reloadable register portion 228. The first LK 
reloadable register portion 222 stores a LKTBW (lock total bandwidth) value, and the second 
LK reloadable register portion 224 stores a LKDBW (lock differential bandwidth) value. 
Similarly, the first TK reloadable register portion 226 stores a TKTBW (track total 
bandwidth) value, and the second TK reloadable register portion 228 stores a LKDBW (lock 
differential bandwidth) value. 

Referring to Fig. 7, the first LK reloadable register portion 222 is capable of being 
coupled to a first LK port 223 for inputting the LKTBW value programmed into the first LK 
reloadable register portion 222 through the first LK port 223. The second LK reloadable 
register portion 224 is capable of being coupled to a second LK port 225 for inputting the 
LKDBW value programmed into the second LK reloadable register portion 224 through the 
second LK port 225. The first TK reloadable register portion 226 is capable of being coupled 
to a first TK port 227 for inputting the TKTBW value programmed into the first TK 
reloadable register portion 226 through the first TK port 227. The second TK reloadable 
register portion 228 is capable of being coupled to a second TK port 229 for inputting the 
TKDBW value programmed into the second TK reloadable register portion 228 through the 
second TK port 229. 

Further referring to Fig. 7, in one embodiment of the present invention, the LKTBW 
value, the LKDBW value, the TKTBW value, and the TKDBW value are programmed into 
the first LK reloadable register portion 222, the second LK reloadable register portion 224, 
the first TK reloadable register portion 226, and the second TK reloadable register portion 
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228, respectively, through the first LK port 223, the second LK port 225, the first TK port 
227, and the second TK port 229, respectively, by software from a computer system 23 1 . 
The first LK reloadable register portion 222, the second LK reloadable register portion 224, 
flie first TK reloadable register portion 226, and the second TK reloadable register portion 
228 may generally be comprised of any type of data storage device known to one of ordinary 
skill in the art of electronics. 

Computer systems and programming values into data storage devices with computer 
systems through ports are known to one of ordinary skill in the art of electronics. An 
example of such software for programming the LKTB W value, the LKDB W value, the 
TKTB W value, and the TKDBW value into the reloadable registers 222, 224, 226, and 228, 
respectively, from the computer system 231 is the "ispDOWNLOAD" software application 
commercially known and available to one of ordinary skill in the art of electronics from 
Lattice Semiconductor Corp. headquartered in Hillsboro, Oregon. 

Referring back to Figs. 6 and 8, a first multiplexer 230 sets a TBW (total bandwidth) 
value to the LKTB W value stored in the first LK reloadable register portion 222 when a 
LOCK signal is not asserted (steps 270 and 274 of Fig. 8) and to the TKTBW value stored in 
the first TK reloadable register portion 226 when the LOCK signal is asserted (steps 270 and 
272 of Fig. 8). A second multiplexer 232 sets a DBW (differential bandwidth) value to the 
LKDB W value stored in the second LK reloadable register portion 224 when the LOCK 
signal is not asserted (steps 270 and 274 of Fig. 8) and to Ihe TKDBW value stored in the 
second TK reloadable register portion 228 when the LOCK signal is asserted (steps 270 and 
272 of Fig. 8). Implementation of multiplexers are known to one of ordinary skill in the art 
of electronics. 

A delta comparator 235 compares the DELTA value from the subtractor 218 witfi the 
DBW value from the second multiplexer 232 and asserts one of a LTP (larger than positive) 
signal or a STN (smaller tiian negative) signal (step 276 of Fig. 8). Implementation of 
comparators for the delta comparator 235 is known to one of ordinary skill in the art of 
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electronics. If the magnitude of the DELTA value is greater than or equal to the DBW value 
and if the DOWN_CNT value is greater than the UP^CNT value such that the DELTA value 
is a positive number, then the LTP signal is asserted (i.e., the LTP signal is asserted as a 
logical high state "1" in step 278 of Fig. 8). Otherwise, the LTP signal is not asserted if the 
magnitude of the DELTA value is not greater than the DBW value (step 280 of Fig. 8) or if 
the DOWN_CNT value is not greater than the UP_CNT value (i.e., the LTP signal remains as 
a logical low state "0"). 

If tiie magnitude of the DELTA value is greater than or equal to the DBW value and 
if the DOWN_CNT value is less than the UP^CNT value such that the DELTA value is a 
negative number, then the STN signal is asserted (i.e., the STN signal is asserted as a logical 
high state "1" in step 278 of Fig. 8). Otherwise, the STN signal is not asserted if the 
magnitude of the DELTA value is not greater than the DBW value (step 280 of Fig. 8) or if 
the DOWN_CNT value is not less than the UP_CNT value (i.e., the STN remains as a logical 
low state "0"). 

A sum comparator 234 compares the SUM value from the adder 216 to the TBW 
value from the first multiplexer 230 (step 282 of Fig. 8) and asserts a WE (write enable) 
signal when the SUM value is greater than or equal to the TBW value (step 284 of Fig. 8). 
hnplementation of comparators for the sum comparator 234 is known to one of ordinary skill 
in the art of electronics. Referring to Fig. 8, at start of operation of the digital filter 204, the 
WE signal is reset to not be asserted (i.e., a logical low state "0" in step 260 of Fig. 8). When 
the SUM value is less than the TBW value, the WE signal is not asserted to remain at the 
logical low state "0" (step 286 of Fig. 8). In that case, operation of the digital filter 204 
returns to step 262 to repeat steps 262, 264, 266, 268, 270, 272, 274, 276, 278, 280, and 282 
for each UP signal pulse or each DN signal pulse generated by the phase transition detector 
202 until the WE signal is asserted. 

If the WE signal is asserted by the sum comparator 234, then a FWD (forward) signal 
is set to the value of the LTP signal by a phase select controller 256, and a BWD (backward) 
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signal is set to the value of the STN signal by the phase select controller 256 (step 284 of Fig. 
8). Implementation of logic for the phase select controller 256 is known to one of ordinary 
skill in the art of electronics. The FWD signal and the BWD signal from the phase select 
controller 256 are input by the phase selector 206. 

If the FWD signal is asserted, the phase selector 206 generates a new ACLK signal 
from the given clock signals (HCLKi. J having a leading phase from a current ACLK signal 
as a new ACLK signal and generates a new SCLK signal from the given clock signals 
(HCLKi,J having a leading phase from a current SCLK signal as a new SCLK signal. If the 
BWD signal is asserted, the phase selector 206 generates a new ACLK signal from the given 
clock signals (HCLKi_J having a lagging phase from a current ACLK signal as a new ACLK 
signal and generates a new SCLK signal from the given clock signals (HCLKi.J having a 
lagging phase from a current SCLK signal as a new SCLK signal If neither the FWD signal 
nor the BWD signal is asserted, the phase selector 206 generates the new ACLK signal to 
remain as the current ACLK signal and generates the new SCLK signal to remain as the 
current SCLK signal. 

Further referring to Figs. 6 and 8, when the WE signal is asserted, if the FWD signal 
and the BWD signal remain not asserted for a predetermined number of WE cycles (i.e., for a 
predetermined number of cycles of repeatmg steps 260, 262, 264, 266, 268, 270, 272, 274, 
276, 278, 280, 282, and 284), then the LOCK signal is asserted as a logical high state "1" by 
a lock detector 236 (steps 288 and 290 of Fig. 8). Otherwise, the LOCK signal remains not 
asserted as a logical low state "0" by the lock detector 236 since LOCK was initially set to 
the logical low state "0" at step 259 of Fig. 8 with the start of operation of the clock recovery 
phase locked loop 200 (steps 288 and 292 of Fig. 8). Implementation of logic circuitry for 
the lock detector 236 is known to one of ordinary skill in the art of electronics. 

When the LOCK signal is asserted as a logical high state "1", the digital filter 204 
operates in tracking (i.e., locked) mode. When the LOCK signal is not asserted to remain at 
the logical low state "0", the digital filter 204 operates in locking mode. Figs. 9 and 10 
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illustrate such tracking and locking modes. Fig. 9 has a high speed serial data input (SDESQ 
signal portion 237 with an example transition time period 238 for making transitions between 
stable bits between time points 239 and 240. An example stable data time period 241 when 
the data bit is stable is between time points 240 and 242. 

A graph 243 illustrates the probability of the occurrence of the data transition at each 
time point within the transition time period 238. Such a graph 243 is a Gaussian distribution 
with the average being at a middle time point 244 of the transition time period 238 as known 
to one of ordinary skill in the art of SERDES transceivers. Li Fig. 9, the ratio of the 
transition time period 238 to the total time period of the transition time period 238 and the 
stable data time period 241 is relatively large such as 0.7 for example. Thus, the Gaussian 
distribution 243 has a relatively large spread (i.e., a relatively large standard deviation). 

In contrast, Fig. 10 illustrates a high speed serial data input (SDIN) signal portion 245 
with an example transition time period 246 for making transitions between stable bits 
between time points 247 and 248. An example stable data time period 249 when the data bit 
is stable is between time points 248 and 250, A graph 251 illustrates the probability of the 
occurrence of the data transition at each time point within the transition time period 246. 
Such a graph 25 1 is a Gaussian distribution with the average being at a middle time point 252 
of the transition time period 246 as known to one of ordinary skill in the art of SERDES 
transceivers. In Fig. 10, the ratio of the transition time period 246 to the total time period of 
the transition time period 246 and the stable data time period 249 is relatively small such as 
0.3 for example. Thus, the Gaussian distribution 251 has a relatively narrow spread (i.e., a 
relatively small standard deviation). 

Typically, the high speed serial data input (SDIN) signal portion 237 of Fig. 9 and the 
high speed serial data input (SDIN) signal portion 245 of Fig. 10 are part of a same high 
speed serial data input (SDIN). However, the high speed serial data input (SDIN) signal 
portion 245 of Fig. 10 with the narrower spread Gaussian distribution 251 is sent toward the 
beginning such that the digital filter 204 locks in relatively quickly. 
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The LKDB W value is smaller than the TKDB W value, and the LKTB W value is 
smaller than the TKTB W value, both smaller by about 50% for example. The DB W value 
and the TBW value are smaller for the smaller spread Gaussian distribution 251 of Fig. 10 for 
faster locking in of the ACLK and the SCLK to the high speed serial data input (SDESI). The 
high speed serial data input (SDIN) signal portion 245 of Fig. 10 with the narrower spread 
Gaussian distribution 251 is sent first. Thus, the digital filter 204 initially operates in locking 
mode (i,e., LOCK - 0) with the DBW value set to the LKDBW value and with the TBW 
value set to the LKTB W value. Once, the digital filter 204 locks in with the LOCK signal 
being set to the logical high state "1", the digital filter 204 operates in tracking mode (i.e., 
LOCK = 1) with the DBW value set to the TKDBW value and with the TBW value set to the 
TKTBW value since the high speed serial data input (SDIN) later has the larger spread 
Gaussian distribution 243 of Fig. 9. 

In any case, one ACLK cycle after the WE signal is asserted, a count reset unit 254 
asserts a CTRS (count reset) signal (step 294 of Fig. 8) such that operation of the clock 
recovery phase locked loop 200 returns to step 260 in Fig. 8, Alternatively, the count reset 
unit 254 also asserts the CTRS signal when a RST (reset) signal is asserted manually 
typically at step 260 of Fig. 8 at the start of operation of the digital filter 204. 
Implementation of such a count reset unit 254 is known to one of ordinary skill in the art of 
electronics. The CTRS signal fi-om the count reset unit 254 is coupled to the up_counter 212, 
the down counter 214, and the phase select controller 256. When the CTRS signal fi-om the 
count reset unit 254 is asserted, the UP_CNT value within the up_counter 212 and the 
DN_CNT value within the down_counter 214 are reset to zero. Thus, the WE signal 
becomes not asserted to the logical low state "0". In addition, the FWD signal and the BWD 
signal from the phase select controller 256 are reset to a logical low state "0". 

When the clock data recovery deserializer 200 of Fig. 6 is used within the SERDES 
transceiver 100 of Fig. 1, the DBW value and the TBW value are bandwidth parameters of 
the digital filter 204 that determine the bit error rate of the recovered parallel data output 

21 



L01-034D2 

(RPDO) of the SERDES transceiver 100. An optimum range of the DBW value and of the 
TBW value for mraimizing the bit error rate varies depending on the communications 
protocol used for sending the high speed serial data input (SDIN). Referring to Figs. 6 and 7, 
with the digital filter 204, different LKDB W, TKDBW, LKTBW, and TKTB W values are 
programmable for minimizing the bit error rate depending on the commimications protocol 
used for sending the high speed serial data input (SDIN). Thus, the SERDES transceiver 
having the digital filter 204 may be used to accommodate multiple communications 
protocols. 

It will be understood by those of skill in the art that the foregoing description is only 
exemplary of the invention and is not intended to limit its application to the structure and 
operation described herein. Many of the components can be implemented in hardware or 
software and in discrete or integrated circuits. Additionally, the bandwidth parameters may 
be programmable into the reloadable registers 222, 224, 226, and 228 by any means known to 
one of ordinary skill in the art of electronics. Furthermore, the present invention may be 
practiced when the reloadable registers 222, 224, 226, and 228 are any types of data storage 
device known to one of ordinary skill in the art of electronics. The present invention may be 
practiced when the reloadable registers 222, 224, 226, and 228 each are part of a respective 
separate data storage device or each are integral portions of a same data storage device, as 
would be apparent to one of ordinary skill in the art of electronics firom the description 
herein. In addition, the timing diagram of Fig. 5 is by way of example only, and the present 
invention may be practiced with other example signals. 

Fig. 1 1 shows a block diagram of a phase selector 300 according to another aspect of 
the present invention. The phase selector 300 includes a phase select signal generator 302 
that generates a plurality of phase select signals (S<1 : 16>) in response to the FWD signal and 
the BWD signal fi-om a digital filter (such as the digital filter 204 of Fig. 6 for example). In 
one embodiment of the present invention, the plurality of phase select signals (S<1 :16>) 
includes sixteen select signals, SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, Sll, S12, S13, S14, 



22 



L01-034D2 

SI 5, and SI 6, generated in that predetemined order. 

In addition, a voltage controlled oscillator (VCO) 304 generates a predetermined 
number of given clock signals HCLKi.n such as the given clock signals HCLKi.8 of Fig. 5 for 
example. Referring to Figs. 1 and 1 1, the VCO 304 (shown outlined in dashed lines in Fig. 
1 1) is part of the clock synthesizer phase locked loop 108 and is not part of the phase selector 
300. The predetermined number of given clock signals HCLKi.„ are arranged in a 
predetermined phase order. The given clock signals HCLKi, HCLK2, HCLK3, HCLK4, 
HCLK55 HCLIC5, HCLK7, and HCLKg for example are arranged in the predetermined phase 
order such that any two adjacent given clock signals have a successive phase difference of 
45 ° . The first clock signal HCLKj and the last clock signal HCLKg in that predetermined 
phase order also have the successive phase difference of 45°. The predetermined number of 
given clock signals HCLKj^^ that are arranged in a predetermined phase order are input to a 
first multiplexer 306. Voltage controlled oscillators for generating such given clock signals 
HCLKi_n are known to one of ordinary skill in the art of electronics. 

In addition, a predetermined number of complementary given clock signals HCLK'i.^ 
are also generated by the voltage controlled oscillator and input to a second multiplexer 308. 
The complementary given clock signals HCLK^.^ are also arranged in a second 
predetermined phase order but each of the complementary given clock signals BCLK.\_^ is 
180° phase shifted firom a respective one of the given clock signals HCLKj^^. For example, 
HCLK'i = HCLK5 is 180° phase shifted from HCLKj, HCLK'2 = HCLKg is 180° phase 
shifted from HCLK2, HCLK'3 = HCLK7 is 180° phase shifted from HCLK3, HCLK'4 = 
HCLKg is 180° phase shifted from HCLK4, HCLK'5 = HCLK^ is 180° phase shifted from 
HCLK4, HCLK'e = HCLK2 is 180° phase shifted from HCLK^, HCLK^ = HCLK3 is 180° 
phase shifted from HCLK7, and HCLK'g = HCLK4 is 180° phase shifted from HCLKg. 

In this manner, the complementary given clock signals HCLK'i, HCLK'2, HCLK'3, 
HCLK'4, HCLK'5, HCLK'e, HCLKV, and HCLK' 8 are arranged in a predetermined phase 
order such that any two adjacent complementary given clock signals have a successive phase 
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difference of 45°. In addition, the first complementary given clock signal HCLK'i and the 
last complementary clock signal HCLK'g in that predetermined phase order also have the 
successive phase difference of 45°. Voltage controlled oscillators for generating such 
complementary given clock signals HCLK'i.^ are known to one of ordinary skill in the art of 
electronics. 

A multiplexer select control 310 controls the first multiplexer 306 to select one of the 
given clock signals HCLKi.^ as a first output clock signal PSA and to select one of the given 
clock signals HCLKi.„ as a second output clock signal PSB, depending on which one of the 
select signals S<1:16> is asserted. The first and second output clock signals PSA and PSB 
are input to a first phase interpolator 312 that outputs a recovered serial clock signal (SCLK) 
that has a phase that is phase interpolated as an average of a first phase of the first output 
clock signal PSA and a second phase of the second output clock signal PSB. 

In addition, the multiplexer select control 310 controls the second multiplexer 308 to 
select one of the complementary given clock signals HCLK'j.^ as a third output clock signal 
PAA and to select one of the complementary given clock signals HCLK'i.„ as a fourth output 
clock signal PAB, depending on which one of the select signals S<1:16> is asserted. The 
third and fourth output clock signals PAA and PAB are input to a second phase interpolator 
314 that outputs a complementary recovered serial clock signal (ACLK) that has a phase that 
is phase interpolated as an average of a third phase of the third output clock signal PAA and a 
fourth phase of the fourth output clock signal PAB. 

The third output clock signal PAA is 180° phase shifted firom the first output clock 
signal PSA, and the fourth output clock signal PAB is 180° phase shifted fi-om the second 
output clock signal PSB. Thus, the complementary recovered serial clock signal (ACLK) 
output by the second phase interpolator 314 is 180° phase shifted fi-om the recovered serial 
clock signal (SCLK) output by the first phase interpolator 312. 

Referring to Fig, 12, according to one embodiment of the present invention, the phase 
select signal generator is comprised of a loop of a pluraUty of bidirectional flip-flops. A 
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respective bidirectional flip-flop generates an output signal as a respective one of the select 
signals S<1 :16>. For example, a first bidirectional flip-flop 322 has a Ql output that is a first 
select signal SI of the select signals S<1 :16>, a second bidirectional flip-flop 324 has a Ql 
output that is a second select signal S2 of the select signals S<1 : 16>, a third bidirectional 
flip-flop 326 has a Ql output that is a third select signal S3 of the select signals S<1:16>, and 
so on up to a sixteenth bidirectional flip-flop 328 having a Ql output that is a sixteenth select 
signal S16 of the select signals S<1:16>. Thus, sixteen bidirectional flip-flops comprise the 
phase select signal generator 302 to generate the sixteen select signals SI, S2, S3, S4, S5, S6, 
S7, S8, S9, SIO, SI 1, S12, S13, S14, S15, and S16 in that predetermined order. 

Each bidirectional flip flop of the phase select signal generator 302 inputs the outputs 
of the two adjacent bidirectional flip flops. In addition, the output of each bidirectional flip 
flop is coupled as inputs for each of the two adjacent bidirectional flip flops. For example, 
referring to Fig. 12, the first bidirectional flip flop 322 is priorly adjacent to the second 
bidirectional flip flop 324, and the third bidirectional flip flop 326 is subsequently adjacent to 
the second bidirectional flip flop 324. 

The output of both adjacent bidirectional flip flops 322 and 326 are input to the 
second bidirectional flip flop 324. Thus, the Q2 output of the first bidirectional flip flop 322 
is a Dl input of the second bidirectional flip flop 324, and the Ql output of the third 
bidirectional flip flop 326 is a D2 input of the second bidirectional flip flop 324. In addition, 
the Ql output of the second bidirectional flip flop 324 is the D2 input of the first bidu-ectional 
flip flop 322, and the Q2 output of the second bidirectional flip flop 324 is the Dl input of 
the third bidirectional flip flop 326. 

The pluraUty of bidirectional flip flops of the phase select signal generator 302 are 
coupled in a closed loop with the first bidirectional flip flop 322 being adjacent the sixteenth 
bidirectional flip flop 328. Thus, the Q2 output of the sixteenth bidirectional flip flop 328 is 
coupled to the Dl input of the first bidirectional flip flop 322, and the Ql output of the first 
bidirectional flip flop 322 is coupled to the D2 input of the sixteenth bidirectional flip flop 
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328. 

In addition, the first bidirectional flip flop 322 is a set flip-flop, and the fifteen 
bidirectional flip flops subsequent to the first bidirectional flip flop 322 in the phase select 
signal generator 302 are reset flip-flops. Fig. 13 shows a more detailed block diagram of the 
first bidirectional flip flop 322 comprised of a set delay flip-flop 330. Fig. 15 shows a more 
detailed block diagram for each of the fifteen bidirectional flip flops, subsequent to the first 
bidirectional flip flop 322, comprised of a reset delay flip-flop 332. 

Referring to Fig. 13, the first bidirectional flip flop 322 is comprised of the set delay 
flip-flop 330 having the D input coupled to an output of a multiplexer 334. Referring to Figs. 
12 and 13, the multiplexer 334 has a Dl input that is coupled to the Q2 output of the 
sixteenth bidirectional flip flop 328 and has a D2 input that is coupled to the Ql output of the 
second bidirectional flip flop 324. In addition, the multiplexer 334 inputs the Q output of the 
set delay flip-flop 330. The Q ou^ut of the set delay flip-flop 330 is the Ql and Q2 outputs 
of the first bidirectional flip flop 322. 

Referring to Fig. 14, the multiplexer 334 selects one of the Dl, D2, and Q inputs as 
the D input to the set delay flip-flop 330 depending on the FWD and BWD signals fi-om a 
digital filter (such as the digital filter 204 of Fig. 6 for example) of a phase locked loop. The 
FWD and BWD signals are input to a NOR gate 336 to generate a STAY signal that is 
asserted to a logical high state "1" if both the FWD signal and BWD signal remain not 
asserted at the logical low state "0". The multiplexer 334 selects the Dl input as the D input 
to the set delay flip-flop 330 if the FWD signal is asserted, selects the D2 input as the D input 
to the set delay flip-flop 330 if the BWD signal is asserted, and selects the Q input as the D 
input to the set delay flip-flop 330 if tiie STAY signal firom the NOR gate 336 is asserted. 

Referring back to Fig. 13, at the next transition of the complementary recovered serial 
clock signal (ACLK), tiie D-input firom the multiplexer 334 is output as the Q-output of the 
set delay flip-flop 330. Because the delay flip-flop 330 of Fig. 13 is a set flip flop, the Q- 
output of the flip-flop 330 is set to a logical high state "1" when the reset signal (RST) is 
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Referring to Fig. 15, a multiplexer 338 that operates substantially same as the 
multiplexer 334 of Fig. 14 determines the D-input of the reset delay flip-flop 332. The Dl 
input is coupled to the Q2 output of a priorly adjacent bidirectional flip flop, and the D2 input 
is coupled to the Ql output of a subsequently adjacent bidirectional flip flop. The Q-output 
of the reset delay flip-flop 332 is also input to the multiplexer 338. The multiplexer 338 
selects the Dl input as the D input to the reset delay flip-flop 332 if the FWD signal is 
asserted, selects the D2 input as the D input to the reset delay flip-flop 332 if the BWD signal 
is asserted, and selects the Q input as the D input to the reset delay flip-flop 332 if the STAY 
signal is asserted when neither the FWD signal nor the BWD signal is asserted. At the next 
transition of the complementary recovered serial clock signal (ACLK), the D-input from the 
multiplexer 338 is output as the Q-output of the reset delay flip-flop 332, Because the delay 
flip-flop 332 of Fig. 15 is a reset flip flop, the Q-output of the flip-flop 332 is reset to a 
logical low state "0" when the reset signal (RST) is asserted. 

Referring to Figs. 1 1, 12, 13, 14, and 15, at flie beginning of operation of the phase 
selector 300, the reset (RST) signal is asserted, and the first select signal SI from the first 
bidirectional flip-flop 322 is set as the logical high state "1" with the set flip-flop 330 while 
the rest of the select signals, S2, S3, S4, S5, S6, S7, S8, S9, SIO, SI 1, S12, S13, S14, S15, 
and SI 6 are each reset to the logical low state "0" with the respective reset flip-flop 332. 
This initial set of select signals SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, Sll, S12, S13, S14, 
S15, and S16 results in a set of recovered serial clock signals ACLK and SCLK. Depending 
on the FWD and BWD signals resulting from such an initial set of the recovered serial clock 
signals ACLK and SCLK, one of the select signals SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, 
Sll, S12, S13, S14, S15, and S16 is asserted to the logical high state "1" as a currently 
asserted select signal while the rest of the select signals are not asserted at the logical low 
state "0". 

Referring to Fig. 1 1, the multiplexer select control 310 controls the first multiplexer 
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306 to select one of the given clock signals HCLKi.„ as the first output clock signal PSA and 

to select one of the given clock signals HCLKi.„ as the second output clock signal PSB, 
depending on which one of the select signals S<1 : 16> is asserted, according to the following 
logical relations: 

5 PSA = HCLKi[Sl + S2] + HCLK2[S3 + S4] + HCLK3[S5 + S6] + HCLK4[S7 + S8] 

+HCLK5[S9 + SIO] + HCLKfiPll + S12] + HCLK7[S13 + S14] + HCLK8[S15 + S16]; and 

PSB = HCLKi[S16 + SI] + HCLK2[S2 + S3] + HCLK3[S4 + S5] + HCLK4[S6 + S7] 
+HCLK5[S8 + S9] + HCLK^[S10 + SIl] + HCLK7[S12 + S13] + HCLKgESH + S15]. 

10 

Implementation of logic for such multiplexer select control 310 such as by a programmable 
logic device for example is known to one of ordinary skill in the art of electronics. Fig. 16 
H shows a table of the respective PSA and PSB clock signals from the first multiplexer 306 
g when each one of the selected signals SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, Sll, S12, S13, 
15 j| S14, S15, and S16 is the currently asserted select signal with the rest of the select signals not 
01 being asserted at the logical low state. 

Q Similarly, referring to Fig. 1 1 , the multiplexer select control 310 controls the second 

multiplexer 308 to select one of the complementary given clock signals HCLK'i.„ as the third 

2| output clock signal PAA and to select one of the complementary given clock signals 

20 y HCLK' 1^ as the fourth output clock signal PAB, depending on which one of the select 

y signals S<1 : 16> is asserted, according to the following logical relations: 

PAA = HCLK'i[Sl + S2] + HCLK'2[S3 + S4] + HCLK'3[S5 + S6] + HCLK%[S7 + S8] 
+HCLK'5[S9 + SIO] + HCLK'eESl 1 + S12] + HCLK^[S13 + S14] + HCLK'g[S15 + S16]; 

and 

25 PAB = HCLK'i[S16 + SI] + HCLK'2[S2 + S3] + HCLK'3[S4 + S5] + HCLK'4[S6 + S7] 

+HCLK'5[S8 -H S9] + HCLK'eLSlO + SI 1] + HCLK'7[S12 + S13] + HCLK^gLSH + S15]. 

Implementation of logic for such multiplexer select control 310 such as by a programmable 
logic device for example is known to one of ordinary skill in the art of electronics. Fig. 17 
30 shows a table of the respective PAA and PAB clock signals from the second multiplexer 308 

when each one of the selected signals SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, SI 1, S12, S13, 
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S14, S15, and S16 is the currently asserted select signal with the rest of the select signals not 
being asserted at the logical low state. 

Referring to Figs. 1 1 and 16, the first phase interpolator 312 inputs the first output 
clock signal PSA and the second output clock signal PSB fi-om the first multiplexer 306. The 
first phase interpolator 312 generates the recovered serial clock signal (SCLK) having a 
phase that is phase interpolated as an average of the first phase of the first output clock signal 
PSA and the second phase of the second output clock signal PSB. Implementation of such 
phase interpolators are known to one of ordinary skill in the art of electronics. Fig. 16 shows 
the phase of the recovered serial clock signal (SCLK) generated by the first phase 
interpolator 312 for each possible set of the first output clock signal PSA and the second 
output clock signal PSB fi-om the first multiplexer 306. 

Referring to Fig. 16, the recovered serial clock signal (SCLK) is a chosen clock signal 
that is one of the given clock signals HCLK^^ when the first output clock signal PSA and the 
second output clock signal PSB are that chosen clock signal. In Fig. 16, the recovered serial 
clock signal (SCLK) is HCLK, as the chosen clock signal when the first output clock signal 
PSA and the second output clock signal PSB are both HCLKj when the first select signal SI 
is asserted. The recovered serial clock signal (SCLK) is HCLK2 as the chosen clock signal 
when the first output clock signal PSA and the second output clock signal PSB are both 
HCLK2 when the third select signal S3 is asserted. The recovered serial clock signal (SCLK) 
is HCLK3 as the chosen clock signal whra the first output clock signal PSA and the second 
output clock signal PSB are both HCLK3 when the fifth select signal S5 is asserted. The 
recovered serial clock signal (SCLK) is HCLK4 as the chosen clock signal when the first 
output clock signal PSA and the second output clock signal PSB are both HCLK4 when the 
seventh select signal S7 is asserted. 

Similarly, the recovered serial clock signal (SCLK) is HCLK5 as the chosen clock 
signal when the first output clock signal PSA and the second output clock signal PSB are 
both HCLK5 when the ninth select signal S9 is asserted. The recovered serial clock signal 
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(SCLK) is HCLK^ as the chosen clock signal when the first output clock signal PSA and the 
second output clock signal PSB are both HCLIQ when the eleventh select signal S 11 is 
asserted. The recovered serial clock signal (SCLK) is HCLK7 as the chosen clock signal 
when the first output clock signal PSA and the second output clock signal PSB are both 
HCLK7 when the thirteenth select signal 813 is asserted. The recovered serial clock signal 
(SGLK) is HCLKg as the chosen clock signal when the first output clock signal PSA and the 
second output clock signal PSB are both HCLKg when the fifteenth select signal S15 is 
asserted. 

Alternatively, fiirther referring to Fig. 16, the recovered serial clock signal (SCLK) is 
one of a leading interpolated clock signal or a lagging interpolated clock signal of a chosen 
clock signal of the given clock signals HCLKj.^ . When the recovered serial clock signal 
(SCLK) is the leading interpolated clock signal of the chosen clock signal, the phase of the 
recovered serial clock signal (SCLK) is phase interpolated as an average of the phase of the 
chosen clock signal and the phase of an adjacent leading clock signal in the phase order of the 
given clock signals HCLKj.^ . For example, assume that the recovered serial clock signal 
(SCLK) is the leading interpolated clock signal of the second given clock signal HCLK2 as 
the chosen clock signal. In that case, the phase of the recovered serial clock signal (SCLK) is 
phase interpolated as an average of the phase of the second given clock signal HCLK2 and the 
phase of the third given clock signal HCLK3 which is the adjacent leading clock signal of the 
second given clock signal HCLKj. 

On the other hand, when the recovered serial clock signal (SCLK) is the lagging 
interpolated clock signal of the chosen clock signal, the phase of the recovered serial clock 
signal (SCLK) is phase interpolated as an average of the phase of the chosen clock signal and 
the phase of an adjacent lagging clock signal in the phase order of the given clock signals 
HCLKi_„ . For example, assume that the recovered serial clock signal (SCLK) is the lagging 
interpolated clock signal of the second given clock signal HCLK2 as the chosen clock signal, 
hi that case, the phase of the recovered serial clock signal (SCLK) is phase interpolated as an 
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average of the phase of the second given clock signal HCLKj and the phase of the first given 
clock signal HCLKi which is the adjacent lagging clock signal of the second given clock 
signal HCLKj. 

In this manner, referring to Fig. 16, sixteen phases are possible for the recovered 
serial clock signal (SCLK) with the one first phase interpolator 312 from the eight given 
clock signals HCLKl^. The sixteen possible phases have a successive phase difference of 
22.5 °, The phase of the recovered serial clock signal (SCLK) depends on which one of the 
selected signals SI, S2, S3, S4, S5, S6, S7, S8, S9, SIO, Sll, S12, S13, S14, S15, and S16 is 
the currently asserted select signal at the logical high state with the rest of the select signals 
not being asserted at the logical low state. 

Referring to Figs. 12, 13, 14, and 15, a prior adjacent one fi-om the currently asserted 
phase select signal in the order of phase select signals SI, S2, S3, S4, S5, S6, S7, S8, S9, 
SIO, Sll, S12, S13, S14, S15, and S16 is asserted as a newly asserted phase select signal 
when the BWD signal is asserted. Alternatively, a subsequently adjacent one from the 
currently asserted phase select signal in the order of phase select signals SI, S2, S3, S4, S5, 
S6, S7, S8, S9, SIO, Sll, S12, S13, S14, S15, and S16 is asserted as the newly asserted phase 
select signal when the FWD signal is asserted. Alternatively, the currently asserted phase 
select signal remains as the newly asserted phase select signal if neither the FWD signal nor 
the BWD signal is asserted. 

In this manner, when a current recovered serial clock signal (SCLK) is a chosen clock 
signal and when a FWD signal is asserted, the chosen clock signal and the adjacent leading 
clock signal of the chosen clock signal are selected as the first output clock signal PSA and 
the second output clock signal PSB. Thus, a newly recovered serial clock signal (SCLK) 
generated by the first phase interpolator 312 is the leading interpolated clock signal of the 
chosen clock signal. 

For example, assume that the current recovered serial clock signal (SCLK) is the 
second given clock signal HCLK2 as the chosen clock signal with the third select signal S3 
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currently being asserted. When the FWD signal is then asserted, the fourth select signal S4 
becomes the newly asserted select signal with the third select signal S3 being not asserted at 
the logical low state. In that case, the second given clock signal HCLK2 as the chosen clock 
signal and the third given clock signal HCLK3 as the adjacent leading clock signal are 
selected as the first output clock signal PSA and the second output clock signal PSB. Thus, 
the newly recovered serial clock signal (SCLK) is the leading interpolated clock signal of the 
second given clock signal HCLK2 having a phase that is phase interpolated as an average of 
the phase of the second given clock signal HCLK2 as the chosen clock signal and the phase of 
the third given clock signal HCLK3 as the adjacent leadmg clock signal 

Alternatively, when a current recovered serial clock signal (SCLK) is a chosen clock 
signal and when a BWD signal is asserted, the chosen clock signal and the adjacent lagging 
clock signal of the chosen clock signal are selected as the first output clock signal PSA and 
the second output clock signal PSB. Thus, the newly recovered serial clock signal (SCLK) 
generated by the first phase interpolator 3 12 is the lagging interpolated clock signal of the 
chosen clock signal. 

For example, assume that the current recovered serial clock signal (SCLK) is the 
second given clock signal HCLK2 as the chosen clock signal with the third select signal S3 
currently being asserted. When the BWD signal is then asserted, the second select signal S2 
becomes the newly asserted select signal with the third select signal S3 being not asserted at 
the logical low state. In that case, the second given clock signal HCLK2 as the chosen clock 
signal and the first given clock signal HCLKj as the adjacent lagging clock signal are 
selected as the first output clock signal PSA and the second output clock signal PSB. Thus, 
the newly recovered serial clock signal (SCLK) is the lagging interpolated clock signal of the 
second given clock signal HCLK2 having a phase that is phase interpolated as an average of 
the phase of the second given clock signal HCLK2 as the chosen clock signal and the phase of 
the first given clock signal HCLKj as the adjacent lagging clock signal. 

Furthermore, when a current recovered serial clock signal (SCLK) is one of a leading 
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or lagging interpolated clock signal and when the FWD signal is asserted, an immediately 
leading one of the given clock signals HCLKi.„ having a phase that leads the current 
recovered serial clock signal (SCLK) by a least phase amount is selected as the first output 
clock signal PSA and the second output clock signal PSB. Thus, the newly recovered serial 
clock signal (SCLK) generated by the first phase interpolator 312 is tiie immediately leading 
one of the given clock signals HCLKi,^ having a phase that leads the current recovered serial 
clock signal (SCLK) by a least phase amount. 

For example, assume that the current recovered soial clock signal (SCLK) is the 
phase interpolated clock signal having a phase that is the average of the phase of the second 
given clock signal HCLK2 and the phase of the Ihird given clock signal HCLK3 with the 
fourth select signal S4 currently being asserted. When the FWD signal is then asserted, the 
fifth select signal S5 becomes the newly asserted select signal with the fourth select signal S4 
being not asserted at the logical low state. In that case, the third given clock signal HCLK3 is 
the immediately leading one of the given clock signals HCLKj.^ having a phase that leads the 
current recovered serial clock signal (SCLK) by a least phase amount and is selected as the 
first output clock signal PSA and the second output clock signal PSB. Thus, the newly 
recovered serial clock signal (SCLK) is the third given clock signal HCLK3 that is the 
immediately leading one of the given clock signals HCLKj^^ having a phase that leads the 
current recovered serial clock signal (SCLK) by a least phase amount. 

On the other hand, when a current recovered serial clock signal (SCLK) is one of a 
leading or lagging interpolated clock signal and when the BWD signal is asserted, an 
immediately lagging one of the given clock signals HCLK^ji having a phase that lags the 
current recovered serial clock signal (SCLK) by a least phase amoimt is selected as the first 
output clock signal PSA and the second output clock signal PSB. Thus, the newly recovered 
serial clock signal (SCLK) generated by the first phase interpolator 312 is the immediately 
lagging one of the given clock signals HCLKi.n having a phase that lags the current recovered 
serial clock signal (SCLK) by a least phase amoimt. 
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For example, assume that the current recovered serial clock signal (SCLK) is the 
phase interpolated clock signal having a phase that is the average of the phase of the second 
given clock signal HCLK2 and the phase of the third given clock signal HCLK3 with the 
fourth select signal S4 currently being asserted. When the BWD signal is then asserted, the 
third select signal S3 becomes the newly asserted select signal with the fourth select signal 
S4 being not asserted at the logical low state. In that case, the second given clock signal 
HCLK2 is the immediately lagging one of the given clock signals HCLKi.^ having a phase 
that lags the current recovered serial clock signal (SCLK) by a least phase amount and is 
selected as the first output clock signal PSA and the second output clock signal PSB. Thus, 
the newly recovered serial clock signal (SCLK) is the second given clock signal HCLKj that 
is the immediately lagging one of the given clock signals HCLKj.^ having a phase that lags 
the current recovered serial clock signal (SCLK) by a least phase amoimt. 

In this manner, the phase of the recovered serial clock signal (SCLK) is adjusted to 
increase by a phase shift of 22.5° whenever the FWD signal is asserted, and to decrease by a 
phase shift of 22.5 ° whenever the BWD signal is asserted. The phase of the recovered serial 
clock signal (SCLK) is thus adjusted until neither the FWD signal nor the BWD signal is 
asserted. When neither the FWD signal nor the BWD signal is asserted, the currently 
asserted phase select signal remains as the newly asserted phase select signal, and the newly 
recovered serial clock signal (SCLK) remains unchanged as the current recovered serial clock 
signal (SCLK). 

Similarly, the complementary recovered serial clock signal (ACLK) is generated by 
the second phase interpolator 314 from the third output clock signal PAA and the fourth 
output clock signal PAB according to the table of Fig. 17. The complementary recovered 
serial clock signal (ACLK) is 180'' phase shifted from the recovered serial clock signal 
(SCLK) since the third output clock signal PAA is 180° phase shifted from the first output 
clock signal PSA and since the fourth output clock signal PAB is 180° phase shifted from the 
second output clock signal PSB. 
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With such a phase selector 300 of this aspect of the present invention, the recovered 
serial clock signal (SCLK) having sixteen possible phases is generated from the eight given 
clock signals HCLKj^n using only one phase interpolator 312. Another phase interpolator 314 
is used to generate the complementary recovered serial clock signal (ACLK) having sixteen 
possible phases from the eight complementary given clock signals HCLK'j.^, Such a 
minimized number of phase interpolators for generating the recovered serial clock signal 
(SCLK) is advantageous for consuming minimized power and chip space by the phase 
selector 300 of the present invention. 

In addition, because the phase select signal generator 302 is a closed loop of 
bidirectional flip-flops with the first bidirectional flip-flop 322 being coupled to the last 
sixteenth bidirectional flip-flop 328, the select signals SI, S2, S3, S4, S5, S6, S7, S8, S9, 
SIO, SI 1, S12, S13, S14, S15, and S16 are properly generated with any drift of the phase of 
the high speed serial data input (SDIN). If the bidirectional flip-flops of the phase select 
signal generator 302 were not coupled in a closed loop, then the select signals SI, S2, S3, 
S4, S5, S6, S7, S8, S9, SIO, Sll, S12, S13, S14, S15, and S16may be stuck with just the 
first select signal SI being repeatedly asserted as the phase of the high speed serial data input 
(SDIN) drifts toward the lagging direction. Or, if the bidirectional flip-flops of the phase 
select signal generator 302 were not coupled in a closed loop, then the select signals SI, S2, 
S3, S4, S5, S6, S7, SB, S9, SIO, Sll, S12, S13, S14, S15, and S16 maybe stuck with just the 
last sixteenth select signal S16 being repeatedly asserted as the phase of the high speed serial 
data input (SDIN) drifts toward the leading direction. 

It will be understood by those of skill in the art that the foregoing description is only 
exemplary of the invention and is not intended to limit its application to the structure and 
operation described herein. Many of the components can be implemented in hardware or 
software and in discrete or integrated circuits. Furthermore, the phase selector using one 
phase interpolator of the present invention may be used for any nimiber of given clock 
signals for doubling the possible number of phases. In addition, the present invention may be 



35 



L01-034D2 

practiced with the phase interpolator generating any phase (aside from just the example of an 
average) that is phase interpolated between the phases of the two clock signals that are input 
to the phase interpolator, as would be apparent to one of ordinary skill in the art of SERDES 
transceivers from the description herein. 

Referring to Fig. 18, in another aspect of the present invention, a CDR (clock data 
recovery) deseriaUzer 400 includes a clock recovery phase locked loop 401, a SYNC 
(synchronization) detect logic 402, a clock divider 404, and a serial-to-parallel shift register 
406. In one embodiment of the present invention, the clock recovery phase locked loop 401 
is implemented as the clock recovery phase locked loop 200 of Fig. 6. The clock divider 404 
receives from the phase locked loop 401 the recovered clock signal (SCLK) having a first 
relatively high frequency such as 1.25 GHz (giga-hertz) for example and generates a divided 
clock signal (i.e., the recovered parallel clock signal, RPCLK) having a second frequency. 
The second frequency of the divided clock signal RPCLK is lowered from the first frequency 
of the recovered clock signal (SCLK) by a predetermined ratio number 'V". Thus, each cycle 
of the divided clock signal RPCLK is generated for each count of cycles of the recovered 
clock signal (SCLK) up to the predetermined ratio number "v". Implementation of such a 
clock divider is known to one of ordinary skill in the art of electronics. 

The serial-to-parallel shift register 406 shifts in bits of the recovered serial data (RSD) 
recovered from the clock recovery phase locked loop 401 with each cycle of the recovered 
clock signal (SCLK). The recovered serial data (RSD) is the high speed serial data input 
(SDIN) sampled at every cycle of the recovered serial clock signal (SCLK) and is ideally 
substantially same as the high speed serial data input (SDIN). Mechanisms within the clock 
recovery phase locked loop 401 such as within the phase transition detector 202 of Fig. 6 for 
example for sampling a data signal with a clock signal to generate the recovered serial data 
(RSD) are known to one of ordinary skill in the art. The serial-to-parallel shift register 406 
outputs the predetermined ratio * V number of bits of the shifted recovered serial data (RSD) 
as the recovered parallel data output (RPDO) at a predetermined transition of every cycle of 
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the divided clock signal (RPCLK). For example, the predetermined ratio "v" number of bits 
of the recovered parallel data output (RPDO) is output by the serial-to-parallel shift register 
406 at each low-to-high transition of every cycle of the divided clock signal (RPCLK). 
Implementation of serial-to-parallel shift registers are known to one of ordinary skill in the 
art of electronics. 

Referring to Fig. 3, when the predetermined ratio 'V" number of bits of the recovered 
parallel data output (RPDO) is three bits wide for example, the low-to-high transition of the 
divided clock signal (RPCLK) may occur at any of three time points for a group of three bits 
of data. Depending on the time point of the low-to-high transition of the divided clock signal 
(RPCLK), the three bits of the recovered parallel data output (RPDO) is partitioned at 
different boundaries of three bits of the high speed serial data input (SDIN). The SYNC 
detect logic 402 according to an embodiment of the present invention asserts a VRS (divider 
ReSet) signal (i.e., a parallel clock enabling signal) to control the occurrence of the time point 
of the predetermined low-to-high transition of the divided clock signal (RPCLK) at the 
desired one of the three possible time points such that the three bits of the recovered parallel 
data output (RPDO) is partitioned at the proper boundaries of three bits of the high speed 
serial data input (SDIN). 

Referring to Fig. 19, the SYNC detect logic 402 according to an embodiment of the 
present invention includes a plurality of reloadable regist^ portions including a first 
reloadable register portion 412, a second reloadable register portion 414, and a third 
reloadable register portion 416. A respective bit pattem of a respective predetermined 
number of data bits for a respective communications protocol is stored in each of the first, 
second, and third reloadable register portions 412, 414, and 416. A first synchronization bit 
pattem comprised of twelve bits PAT<1:12> for a first communications protocol for example 
is stored within the first reloadable register portion 412. A second synchronization bit pattem 
comprised often bits PAT<1 :10> for a second commimications protocol for example is 
stored within the second reloadable register portion 414. A third synchronization bit pattem 
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comprised of another ten bits PAT<1 1 :20> for the second communications protocol for 
example is stored within the third reloadable register portion 416. 

Each of the first, second, and third synchronization bit patterns corresponds to a 
respective communications protocol. For example, the first synchronization bit pattem 
comprised of twelve bits PAKl :12> may be for the "10B/12B" Serial Data Protocol as 
known to one of ordinary skill in the art of SERDES transceivers. Such twelve bits typically 
are comprised of a successive number of logical high "1" data bits and a successive number 
of logical low "0" databitssuchas"! 1 1 1 1 1 000000" or"l 1 1 000 1 1 1000" for 
example. The second and third synchronization bit patterns comprised often bits each may 
be for the "8B/10B" Fibre Channel Serial Data Protocol as known to one of ordinary skill in 
the art of SERDES transceivers. For example, the second synchronization bit pattem may be 
a +K28.5 bit pattem "1 1 0 0 0 0 0 1 0 1", and the third synchronization bit pattem may be a 
-K28.5 bit pattem "0 01111101 0", for example. However, such synchronization bit 
patterns for such communications protocols are by way of example only. Thus, the present 
invention may be practiced for any synchronization bit pattem for the first, second, and third 
synchronization bit pattems stored within the first, second, and third reloadable register 
portions 412, 414, and 416 for any communications protocol. 

Referring to Fig. 20, the first, second, and third synchronization bit pattems are 
programmed into the first, second, and thh-d reloadable register portions 412, 414, and 416, 
respectively, with software firom a computer system 418. The first reloadable register portion 
412 is capable of being coupled to a first port 422 for receiving and storing the first 
synchronization bit pattem programmed by the computer system 418 through the first port 
422. The second reloadable register portion 414 is capable of being coupled to a second port 
424 for receiving and storing the second synchronization bit pattem programmed by the 
computer system 41 8 throu^ the second port 424. The third reloadable register portion 41 6 
is capable of being coupled to a third port 426 for receiving and storing the third 
synchronization bit pattem programmed by the computer system 418 through the third port 



38 



L01-034D2 
426. 

In the example of Fig. 20, each of the first, second, and third reloadable register 
portions 412, 414, and 416 are each part of a separate respective reloadable register coupled 
to a separate respective one of the first, second, and third ports 422, 424, and 426. In 
contrast, referring to Fig. 21, the first, second, and third reloadable register portions 412, 414, 
and 416 are each part of a same one reloadable register 428. For example, the reloadable 
register 428 may be comprised of twenty data bits PAT<1 :20> with each of the first, second, 
and third synchronization bit pattems being programmed into a respective portion of the one 
reloadable register 428. 

For example, the first synchronization bit pattem is programmed through a port 430 
as the first twelve bits PAT<1:12> of the one reloadable register 428 when the high speed 
serial data input (SDIN) is for the "10B/12B" Serial Data Protocol. Or, when the high speed 
serial data input (SDIN) is for the "8B/10B'' Fibre Channel Serial Data Protocol, the second 
synchronization bit pattem is programmed through the port 430 as the first ten bits 
PAT<1 : 10> of the one reloadable register 428, and the third synchronization bit pattem is 
programmed through the port 430 as the last ten bits PAT<1 1 :20> of the one reloadable 
register 428. 

The reloadable registers 412, 414, 416, and 428 may be any type of programmable 
data storage device as known to one of ordinary skill in the art of electronics. The present 
invention may be practiced when the reloadable registers 412, 414, and 416 each are part of a 
respective separate data storage device or each are integral portions of a same data storage 
device, as would be apparent to one of ordinary skill in the art of electronics from the 
description herein. Computer systems and programming values into data storage devices 
with computer systems through ports are known to one of ordinary skill in the art of 
electronics. An example of such software for programming the first, second, and third 
synchronization bit pattems into the first, second, and third reloadable registers 412, 414, and 
416, respectively, or into the one reloadable register 428, from the computer system 418 is 
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the "ispDOWNLOAD'' software application commercially known and available to one of 
ordinary skill in the art of electronics from Lattice Semiconductor Corp. headquartered in 
Hillsboro, Oregon. 

Referring back to Fig. 19, a first bit pattern comparator 432 inputs an intermediate 
parallel data output (IPDO) from the serial-to-parallel shift register 406 with each cycle of the 
recovered clock signal (SCLK). The IPDO is the v-bits of the recovered serial data (RSD) 
shifted into the shift register 406 with each bit of the recovered serial data (RSD) being 
shifted at each cycle of the recovered clock signal (SCLK). In addition, the first bit pattern 
comparator 432 compares for every cycle of the recovered clock signal (SCLK) the 
predetermined number of bits of flie first synchronization bit pattem stored within the first 
reloadable register portion 412 to a same predetermined number of bits of the intermediate 
parallel data output (IPDO) from the shift register 406. The first bit pattem comparator 432 
asserts a first comparator output signal (VRS^) when the first synchronization bit pattem 
stored within the first reloadable register portion 412 is substantially same as a predetermined 
number of bits of the intermediate parallel data output (IPDO) from the shift register 406. 
Implementation of such a bit pattem comparator is known to one of ordinary skill in the art of 
electronics. 

In addition, a second bit pattem comparator 434 inputs the intermediate parallel data 
output (IPDO) from the serial-to-parallel shift register 406 with each cycle of the recovered 
clock signal (SCLK). The second bit pattem comparator 434 compares for every cycle of the 
recovered clock signal (SCLK) the predetermined number of bits of the second 
synchronization bit pattem stored within the second reloadable register portion 414 to a same 
predetermined number of bits of the intermediate parallel data output (IPDO) from the shift 
register 406. The second bit pattem comparator 434 asserts a second comparator output 
signal (VRS2) when ftie second synchronization bit pattem stored within the second 
reloadable register portion 414 is substantially same as a predetermined number of bits of the 
intermediate parallel data output (IPDO) from the shift register 406. Implementation of such 
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a bit pattern comparator is known to one of ordinary skill in the art of electronics. 

Furthermore, a third bit partem comparator 436 inputs the intermediate parallel data 
output (IPDO) from the serial-to-parallel shift register 406 with each cycle of the recovered 
clock signal (SCLK). The third bit pattern comparator 436 compares for every cycle of the 
recovered clock signal (SCLK) the predetermined number of bits of the third synchronization 
bit pattem stored within the third reloadable register portion 416 to a same predetermined 
number of bits of the intermediate parallel data output (IPDO) from the shift register 406. 
The third bit pattem comparator 436 asserts a third comparator output signal (VRS3) when 
the third synchronization bit pattem stored within the third reloadable register portion 416 is 
substantially same as a predetermined number of bits of the intermediate parallel data output 
(IPDO) from the shift register 406. Implementation of such a bit pattem comparator is 
known to one of ordinary skill in the art of electronics. 

The second comparator output signal (VRS2) and the third comparator output signal 
(VRS3) are input to an OR-gate 438, and the output of the OR-gate 438 is input to a 
miiltiplexer 440. The first comparator output signal (VRSj) is also input to the multiplexer 
440. The output of the multiplexer 440 is determined by the MODE signal which indicates 
the communications protocol of the recovered serial data (RSD). When the MODE signal 
indicates that the recovered serial data (RSD) is for the first communications protocol of the 
first synchronization bit pattem stored within the first reloadable register portion 412, the 
first comparator output signal (VRSj) is gated as the output of the multiplexer 440 as the 
VRS signal (i.e., the parallel clock enabling signal). When the MODE signal indicates that 
the recovered serial data (RSD) is for the second communications protocol of the second and 
third synchronization bit patterns stored within the second and third reloadable register 
portions 414 and 416, the output of the OR-gate 438 is gated as the output of the multiplexer 
440 as tiie VRS signal (i.e., the parallel clock enabling signal). 

Referring to Figs. 1 8 and 19, the VRS signal is input by the clock divider 404, and the 
time point when the VRS signal is asserted determines the predetermined transition of the 
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recovered parallel clock signal (RPCLK) that determines the proper partitioning of the 
recovered serial data (RSD) to form the recovered parallel data output (RPDO). In this 
manner, the VRS signal is asserted differently depending on the communications protocol of 
the high speed serial data input (SDIN) to properly partition the recovered serial data (RSD) 
to form the recovered parallel data output (RPDO). Thus, the CDR (clock data recovery) 
deserializer 400 accommodates multiple conraiunications protocols of the high speed serial 
data input (SDIN) for proper partitioning of the recovered serial data (RSD) to form the 
recovered parallel data output (RPDO). 

Referring to Fig. 22, m another embodiment of the SYNC detect logic 449, a 
multiplexer 450 is disposed after the first, second, and third reloable registers 412, 414, and 
416 and before a bit pattern comparator 452. In this embodiment, the multiplexer 450 selects 
one of the first, second, and third synchronization bit patterns from the first, second, and third 
reloable registers 412, 414, and 416 depending on the communications protocol as indicated 
by the MODE signal. The selected synchronization bit pattern &om the multiplexer 450 is 
input by the bit pattem comparator 452. 

The bit pattem comparator 452 inputs the intermediate parallel data output (IPDO) 
fi-om the serial-to-parallel shift register 406 with each cycle of the recovered clock signal 
(SCLK). The bit pattem comparator 452 compares for every cycle of the recovered clock 
signal (SCLK) the predetermined number of bits of the selected synchronization bit pattem to 
a same predetermined number of bits of the intermediate parallel data output (IPDO) from the 
shift register 406. The bit pattem comparator 452 asserts the VRS signal when the selected 
synchronization bit pattem from the multiplexer 450 is substantially same as a predetermined 
number of bits of the intermediate parallel data output (IPDO) firom the shift register 406. 
Implementation for the multiplexer 450 and the bit pattem comparator 452 is known to one 
of ordinary skill in the art of electronics. 

It will be understood by those of skill in the art that the foregoing description is only 
exemplary of the invention and is not intended to limit its application to the structure and 
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operation described herein. Many of the components can be implemented in hardware or 
software and in discrete or integrated circuits. Furthermore, the SYNC detect logic 402 of 
Fig. 19 may be comprised of any number of reloadable register portions and corresponding 
bit pattem comparators for accommodating any number of communications protocols of the 
high speed serial data input (SDIN). 

Additionally, the present invention may be practiced when the reloadable register 
portions 412, 414, and 416 are any types of data storage device known to one of ordinary 
skill in the art of electronics. The present invention may be practiced when the reloadable 
registers 412, 414, and 416 each are part of a respective separate data storage device or each 
are integral portions of a same data storage device, as would be apparent to one of ordinary 
skill in the art of electronics from the description herein. In addition, the OR-gate 438 is only 
an example of combinational logic of comparator output signals that may be gated as the 
VRS signal. In addition, a bit pattem comparator may compare the predetermined number of 
bits of the selected synchronization bit pattem to a same predetermined mmiber of bits of the 
shifted recovered serial data (RSD) for other numbers of cycles of the recovered clock signal 
(SCLK), aside from just the example of comparing for every single cycle of the recovered 
clock signal (SCLK). 

The present invention is limited only as defined in the following claims and 
equivalents thereof 
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